<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  <meta http-equiv="X-UA-Compatible" content="ie=edge" />
  <title>Document</title>
  <!-- 导入样式表 -->
  <link rel="stylesheet" href="./assets/news.css" />
</head>

<body>

  <!-- 新闻列表 -->
  <div id="news-list">
    <!-- 新闻的 item 项 -->
    <div class="news-item">
      <img class="thumb" src="" alt="" />
      <div class="right-box">
        <!-- 新闻标题 -->
        <h1 class="title">5G商用在即，三大运营商营收持续下降</h1>
        <div class="footer">
          <div>
            <!-- 新闻来源 -->
            <span>胡润百富</span>&nbsp;&nbsp;
            <!-- 发布日期 -->
            <span>2019-10-28 10:14:38</span>
          </div>
          <!-- 评论数量 -->
          <span>评论数：66</span>
        </div>
      </div>
    </div>
  </div>

  <!-- 
    目标:
      1. 获取数据
         通过 axios 发送请求 get
         请求地址: http://localhost:3000/api/news
      2. 渲染页面
  -->

  <!-- 导入axios -->
  <script src="./lib/axios.js"></script>
  <script>
    const list = document.querySelector('#news-list')

    // 封装一个方法, 初始化文章列表数据
    function initNews() {
      axios({
        method: 'get',
        url: 'http://localhost:3000/api/news'
      }).then(({ data: res }) => {
        // 先解构出data, 再重命名成语义更好的 res
        if (res.code === 200) {
          // 根据后台返回的数组, 进行列表的渲染
          list.innerHTML = res.data.map((item) => {
            return `
              <!-- 新闻的 item 项 -->
              <div class="news-item">
                <img class="thumb" src="http://localhost:3000${item.img}" alt="" />
                <div class="right-box">
                  <!-- 新闻标题 -->
                  <h1 class="title">${item.title}</h1>
                  <div class="footer">
                    <div>
                      <!-- 新闻来源 -->
                      <span>${item.source}</span>&nbsp;&nbsp;
                      <!-- 发布日期 -->
                      <span>${item.time}</span>
                    </div>
                    <!-- 评论数量 -->
                    <span>评论数：${item.cmtcount}</span>
                  </div>
                </div>
              </div>
            `
          }).join('')
        }
      })
    }
   
    initNews()

  </script>
</body>

</html>